

Fig. 2



Fig. 3(a)

| instruction | first<br>operand | second<br>operand | machine<br>language |
|-------------|------------------|-------------------|---------------------|
| ADD         | Ra,              | Rb                | b000                |
| SUB         | Ra,              | Rb                | b001                |
| AND         | Ra,              | Rb                | b010                |
| OR          | Ra,              | Rb                | b011                |
| LD          | Ra,              | @Rb               | b100                |
| ST          | Ra,              | @Rb               | b101                |
| SET         | Ra,              | IMD               | b110                |
| MOV         | Ra,              | Rb                | b111                |

Fig. 3(b)

| register | machine<br>language |  |
|----------|---------------------|--|
| RO       | b00                 |  |
| R1       | b01                 |  |
| R2       | b10                 |  |
| R3       | b11                 |  |



## Fig. 5

```
/* hwmodel.h */
extern short IMEM[N1];
extern short DMEMA[N2];
extern short DMEMA[N3];

extern short IR;
extern short PC;
extern short R0;
extern short R1;
extern short R2;
extern short R3;

extern void ALU(short, short, short*, int);
extern void MEMC(short, short*, int);
enum {
   ADD=0, SUB, AND, OR
};
```

```
short IMEM[N1];
short DMEMA[N2];
short DMEMB[N3];
short IR, PC, RO, R1, R2, R3;
void ALU(short IN1, short IN2, short *OUT, int CTL) {
switch (CTL) {
  case 0: // ADD
   *OUT = IN1 + IN2;
   break;
  case 1; // SUB
   *OUT = IN1 - IN2:
   break;
          // AND
 case 2;
   *OUT = IN1 & IN2;
   break:
 case 3; // OR
   *OUT = IN1 | IN2;
   break;
 }
}
void MEMC(short AD, short *DB, int RW) {
 switch (RW) {
  case 1: // Read
    if (AD < 0x100)
      *DB = DMEMA[AD & OxFF];
    eise
      *DB = DMEMB[AD & OxFF];
   break:
  case 0: // Write
   if (AD < 0x100)
      DMEMA[AD & 0xFF] = *DB;
      DMEMB[AD & OxFF] = *DB;
    break:
 }
}
```

Fig. 7

```
#include "hwmodel.h"
void ADD(short *RS1, short RS2) {
 ALU(*RS1, RS2, RS1, ADD);
void SUB(short *RS1, short RS2) {
 ALU(*RS1, RS2, RS1, SUB);
void AND(short *RS1, short RS2) {
 ALU(*RS1, RS2, RS1, AND);
void OR(short *RS1, short RS2) {
 ALU(*RS1, RS2, RS1, OR);
void LD(short *RS1, short RS2) {
  MEMC(RS2, RS1, 1);
void ST(short *RS1, short RS2) {
 MEMC (RS2, RS1, 0):
void SET(short *RS1, short IMD) {
 *RS1 = IMD;
void MOV(short *RS1, short RS2) {
  *RS1 = RS2;
```

Fig. 8(a)

```
/* inst.h */
extern void ADD(short *, short);
extern void SUB(short *, short);
extern void AND(short *, short);
extern void OR(short *, short);
extern void LD(short *, short);
extern void ST(short *, short);
extern void SET(short *, short);
extern void MOV(short *, short);
```

Fig. 8(b)



```
#include "hwmodel.h"
enum (
  Fetch=0, Decode, Exec
int
       cycle:
int
       state;
       *reg[4] = \{&R0, &R1, &R2, &R3\};
int
main() {
 cycle = 0;
  state = Fetch:
  while (exec());
  printf("cycle-%d\n", cycle);
int exec() {
 int cd[3];
 cycle++;
 switch (state) {
  case Fetch:
    IR - IMEM[PC];
    if (IR < 0)
      return 0;
    else {
      PC++:
      state = Decode;
      return 1;
  case Decode:
    cd[0] = (1R>>4)&0x7;
    cd[1] = (IR>>2)&0x3:
    cd[2] = IR \& 0x3;
    return 1;
  case Exec:
    if (cd[0]=0x0)
      ALU(*reg[cd[1]], *reg[cd[2]], reg[cd[1]], ADD);
    else if((IR>>4) == 0x1)
      ALU(*reg[cd[1]], *reg[cd[2]], reg[cd[1]], SUB);
    state = Fetch;
    return 1;
```

```
short IMEM[N1];
short DMEMA[N2];
short DMEMB[N3];
short IR, PC, R0, R1, R2, R3;
long cycle:
double power;
void ALU(short IN1, short IN2, short *OUT, int CTL) {
  switch (CTL) {
  case ADD:
    *OUT = IN1 + IN2;
    break:
  case SUB:
    *OUT = IN1 - IN2;
    break;
  case AND:
    *OUT = IN1 & IN2;
    break:
  case OR:
    *OUT = IN1 | IN2;
    break;
  }
  cycle += 1;
  power += 0.01;
}
void MEMC(short AD, short *DB, int RW) {
  switch (RW) {
   case 1: // Read
     if (AD < 0x100)
       *DB = DMEMA[AD & OxFF];
     else
       *DB = DMEMB[AD & OxFF];
   <u>cycle += 1;</u>
   power += 0.02;
   break;
   case 0: // Write
     if (AD < 0x100)
       DMEMA[AD & OxFF] = *DB;
       DMEMB[AD & OxFF] = *DB;
   <u>cycle += 2;</u>
   power += 0.04;
   break:
```

```
#include "hwmodel.h"
void ADD(short *RS1, short RS2) {
  ALU (*RS1, RS2, RS1, ADD);
void SUB(short *RS1, short RS2) {
  ALU (*RS1, RS2, RS1, SUB);
void AND(short *RS1, short RS2) {
  ALU (*RS1, RS2, RS1, AND);
void OR(short *RS1, short RS2) {
  ALU (*RS1, RS2, RS1, OR);
void LD(short *RS1, short RS2) {
  MEMC (RS2, RS1, 1);
void ST(short *RS1, short RS2) {
  MEMC (RS2, RS1, 0);
void SET(short *RS1, short IMD) {
  *RS1 = IMD;
  <u>cycle += 1;</u>
  power += 0.005;
void MOV(short *RS1, short RS2) {
  *RS1 = RS2;
  cycle += 1;
  power += 0.005;
```

Fig. 13

Fig. 14

```
#include "hwmodel.h"
       cycle;
long
       code;
long
double power;
void ADD(short *RS1, short RS2) {
  ALU(*RS1, RS2, RS1, ADD);
  cycle += cycle_tb1[0];
  power += power_tb1[0];
  code += 2;
void SUB(short *RS1, short RS2) {
  ALU(*RS1, RS2, RS1, SUB);
  cycle += cycle_tb1[1];
  power += power_tb1[1];
  code += 2;
void LD(short *RS1, short RS2) {
  MEMC(RS2, RS1, 1);
  cycle += cycle_tb1[4];
  power += power_tb1[4];
  code += 2;
void ST(short *RS1, short RS2) {
  MEMC(RS2, RS1, 0):
  cycle += cycle_tb1[5];
  power += power_tb1[5];
  code += 2;
void MOV(short *RS1, short RS2) {
  *RS1 = RS2;
  cycle += cycle_tb1[7];
  power += power_tb1[7];
  code += 2;
```

Fig. 15(a)

| instruction | index | cycle_tbl[ ] | power_tbl[] |
|-------------|-------|--------------|-------------|
| ADD         | 0     | 1            | 0. 01       |
| SUB         | 1     | 1            | 0. 01       |
| AND         | 2     | 1            | 0. 01       |
| OR          | 3     | 1            | 0. 01       |
| LD          | 4     | 2            | 0. 02       |
| ST          | 5     | 3            | 0. 03       |
| SET         | 6     | 1            | 0. 005      |
| MOV         | 7     | 1            | 0. 005      |

Fig. 15(b)